

# I<sup>2</sup>C Controller for Serial EPROMs

January 2015 Reference Design RD1006

### Introduction

The I<sup>2</sup>C bus provides a simple two-wire means of communication. This protocol supports multi-masters and provides a low-speed connection between intelligent control devices, such as microprocessors, and general-purpose circuits, such as memories.

This reference design documents an I<sup>2</sup>C controller designed to interface with serial EEPROM devices. The design can be used with a microprocessor to read the configuration data from a serial EEPROM that supports an I<sup>2</sup>C protocol. It is intended to be a simple I<sup>2</sup>C master using 7-bit addresses and providing random reads cycles only. Typically, serial EEPROMs are programmed at the time of board assembly. They store configuration information which is read by a microprocessor during power-up.

This design is implemented in Verilog and VHDL. Lattice design tools are used for synthesis, place and route and simulation. The design can be targeted to multiple Lattice device families. Its small size makes it portable across different FPGA/CPLD architectures.

This design assumes the user has experience with I<sup>2</sup>C controllers. Information available in the documents listed below is not repeated in this document.

### References

- National Semiconductor NM24C16 16,384-Bit Serial EEPROM
- Philips I<sup>2</sup>C Specification
- · Lattice Semiconductor Data Sheets

## **Theory of Operation**

#### Overview

This I<sup>2</sup>C controller provides an interface between standard microprocessors and I<sup>2</sup>C serial EEPROM devices. It acts as an I<sup>2</sup>C master to support random read cycles from the serial EEPROM. The design consists of the following modules:

I2c Top-level module

I2c clk Clock generation module

I2c rreg Read register module

I2c\_st State machine module

• I2c\_wreg Write register module

Figure 1 provides a top-level block diagram for the I<sup>2</sup>C controller reference design.



Figure 1. PC Controller Top-Level Block Diagram



## **Top-Level Signal Descriptions**

Table 1 provides descriptions of the input/output signals of the I<sup>2</sup>C controller. Signals ending with "\_L" indicate an active low signal. This convention is used throughout the design. The chip select signal is assumed synchronous to the clock. Address, data and the read/write signals are assumed valid at the assertion of the chip select.

Table 1. PC Signal Descriptions

| Interface                   | Signal      | Туре   | Description                                      |  |
|-----------------------------|-------------|--------|--------------------------------------------------|--|
|                             | CS_L        | Input  | I <sup>2</sup> C chip select from microprocessor |  |
|                             | RD_WR_L     | Input  | Write pulse from microprocessor                  |  |
|                             | ADDR[1:0]   | Input  | Address bus from microprocessor                  |  |
| N 4:                        | DATA[7:0]   | I/O    | Microprocessor data bus                          |  |
| Microprocessor<br>Interface | CLK         | Input  | Input clock from microprocessor, 50MHz           |  |
|                             | RST_L       | Input  | Asynchronous reset                               |  |
|                             | REG_CLK_IN  | Input  | Clock used to latch word address                 |  |
|                             | ACK_L       | Output | Microprocessor cycle acknowledge                 |  |
|                             | REG_CLK_OUT | Output | Generated clock to latch word address            |  |
| I <sup>2</sup> C Interface  | SCL_PIN     | Output | I <sup>2</sup> C clock pin                       |  |
|                             | SDA_PIN     | I/O    | I <sup>2</sup> C data pin                        |  |

### **Register Descriptions**

Table 2 lists the I<sup>2</sup>C controller registers.

Table 2. I<sup>2</sup>C Registers

| Register     | Address | Туре       |
|--------------|---------|------------|
| Word Address | 00      | Read/Write |
| Data         | 01      | Read       |
| Status       | 10      | Read       |



### **Design Module Description**

#### **I2C CLK Module**

The I2C\_CLK module provides a one-microprocessor clock tick wide pulse every 5µsec. This is used to control the state machine. The 8-bit counter in this module can be adjusted to meet the needs of any design. If a faster microprocessor clock is used, a bigger counter will be needed. If it is desired to run the I<sup>2</sup>C bus at a faster speed, the counter can be smaller. This design assumes a microprocessor clock frequency of 50MHz.

### **I2C\_RREG Module**

The I2C\_RREG module provides a multiplexor for reading data back to the CPU. The word address, the data read from the I<sup>2</sup>C device and status information can be read back. The status register bits are defined in Table 3.

Table 3. Status Register Bits

| Bit | Signal  | Description                                                             |
|-----|---------|-------------------------------------------------------------------------|
| 7   | ready   | The I <sup>2</sup> C device has responded back with read data.          |
| 6   | ack_err | The I <sup>2</sup> C device did not acknowledge the current read cycle. |
| 0   | Active  | An I <sup>2</sup> C cycle is in progress.                               |

#### **I2C ST Module**

The state machine used in this module is shown in Figure 2. It starts from the IDLE state and waits for the i2c\_go signal from the I2C\_WREG module. Once i2c\_go is asserted, the state machine goes through various i2c states to ensure proper address/data transfers. The ACK signals are inserted by the serial EPROM, which is the slave I<sup>2</sup>C device in this design. The I2C\_st module provides:

- A state machine to control the I<sup>2</sup>C cycles
- A bit counter to count the bit phases
- I<sup>2</sup>C clock generation
- I<sup>2</sup>C data generation
- · Ready generation
- · Error generation



Figure 2. State Machine



#### **I2C WREG Module**

The I2C\_WREG module provides the word address register. When this register is written to, an i2c\_go signal is generated. This causes the state machine to start a random read cycle to the address stored in this register.

A clock, reg\_clk\_out, is generated in this module to allow the use of input registers for the word address register in certain CPLD/FPGA architectures. In order to use the input registers, this clock signal must be routed to a dedicated clock input pin on the board. Please refer to the device data sheet for architectural details.

A microprocessor acknowledge signal is provided in this module. This is the chip select signal delayed by one clock tick. This signal can be omitted from the design if the function is not needed or is performed elsewhere.

### **I2C Module**

The I2C module provides the top-level logic for the design. It links together the individual modules and tri-state buffer for the microprocessor data. It also provides the open drain outputs for the I2C clock and data signals.

### **Test Bench Description**

The test bench for this design includes the following modules:

- CLK\_RST
- I2C\_SLAVE
- I2C\_TB
- MICRO



#### **CLK RST Module**

The CLK\_RST module provides the clock and reset signals to the test bench. Editing the CLK\_PERIOD parameter changes the clock frequency. Editing the RESET\_TIME parameter changes the duration of reset. The reset\_recovery parameter delays the clock until a fixed time, allowing all registers to recover from reset.

#### **I2C SLAVE Module**

The I2C\_SLAVE module provides a model of a I<sup>2</sup>C memory device which features 256 memory locations. The slave module is able to detect START and STOP commands from the I<sup>2</sup>C controller. It generates ACK after the word address cycle and leaves the I<sup>2</sup>C bus tristated after data read. The data stored in the memory is the same as its address. This provides a convenient way to check the data by comparing "Slave Data Receive on Write" and "Slave Data Transmitted on Read" messages during simulation.

#### **I2C TB Module**

The I2C\_TB module is the top-level test bench for the design. It instantiates the I<sup>2</sup>C controller as well as the modules in the test bench.

#### **MICRO Module**

The MICRO module provides the microprocessor stimulus to the I<sup>2</sup>C controller. This module provides tasks to simulate write and read cycles to the I<sup>2</sup>C controller. It also performs error checking on the data read back from the I<sup>2</sup>C controller.

## **Design Flow**

Lattice design tools are used for synthesis, place and route and simulation. In addition to the place and route/fitter engine, the Lattice ispLEVER® design tool includes Synplify®/SynplifyPro® from Synplicity®, and Active-HDL® from Aldec®. The details of the design flow can be found in the README.txt file that comes with the reference design.

## **Timing Diagrams**

The following timing diagrams show the major timing milestones in the simulation.

### **Microprocessor Write Cycle**

The microprocessor writes a "55" to the word address register. This causes the I<sup>2</sup>C controller state machine to start a random read cycle to the I<sup>2</sup>C device.

Figure 3. Microprocessor Write Cycle Timing Diagram



### **Microprocessor Read Cycle**

The microprocessor reads the status register. Bit 1 is set indicating an I<sup>2</sup>C cycle is in progress. Bits 6 and 7 are cleared. This indicates the cycle has not completed and that an error has not been detected.



Figure 4. Microprocessor Read Cycle Timing Diagram



## I<sup>2</sup>C Device Address Write Cycle

An I<sup>2</sup>C cycle starts, followed by the device address and an acknowledge from the I<sup>2</sup>C device.

Figure 5. I'C Device Address Write Cycle Timing Diagram



## I<sup>2</sup>C Word Address Cycle

The word address cycle starts, followed by an acknowledge from the I<sup>2</sup>C device.

Figure 6. PC Word Address Cycle Timing Diagram





### I<sup>2</sup>C Device Address Read Cycle

The second device address cycle, this time requesting a read.

Figure 7. & C Device Address Read Cycle Timing Diagram



### I<sup>2</sup>C Read Data Cycle

The data is read from the I<sup>2</sup>C device. This cycle is done without an acknowledge. A stop is asserted by the controller.

Figure 8. PC Read Data Cycle Timing Diagram





## **Microprocessor Read Status Cycle**

The status register is read indicating the I<sup>2</sup>C cycle has completed.

Figure 9. Microprocessor Read Status Cycle Timing Diagram



## **Microprocessor Read Data Cycle**

The I<sup>2</sup>C data is read by the microprocessor.

Figure 10. Microprocessor Read Data Cycle Timing Diagram





## **Implementation**

This design is implemented in Verilog and VHDL. When using this design in a different device, density, speed, or grade, performance and utilization may vary. Default settings are used during the fitting of the design.

Table 3. Performance and Resource Utilization

| Device Family                    | Language    | Speed Grade | Utilization   | Fmax(MHz) | I/Os | Architecture<br>Resources |
|----------------------------------|-------------|-------------|---------------|-----------|------|---------------------------|
| ECP5™ <sup>6</sup>               | Verilog-LSE | -6          | 86 LUTs       | >50       | 18   | N/A                       |
|                                  | Verilog-Syn | -6          | 87 LUTs       | >50       | 18   | N/A                       |
|                                  | VHDL-LSE    | -6          | 85 LUTs       | >50       | 18   | N/A                       |
|                                  | VHDL-Syn    | -6          | 89 LUTs       | >50       | 18   | N/A                       |
| LatticeECP3™ <sup>3</sup>        | Verilog-Syn | -6          | 96 LUTs       | >50       | 18   | N/A                       |
| LatticeEOF3                      | VHDL-Syn    | -6          | 94 LUTs       | >50       | 18   | N/A                       |
|                                  | Verilog-LSE | -6          | 85 LUTs       | >50       | 18   | N/A                       |
| MachXO3L™ <sup>7</sup>           | Verilog-Syn | -6          | 85 LUTs       | >50       | 18   | N/A                       |
| MacnXO3L1M                       | VHDL-LSE    | -6          | 85 LUTs       | >50       | 18   | N/A                       |
|                                  | VHDL-Syn    | -6          | 86 LUTs       | >50       | 18   | N/A                       |
|                                  | Verilog-LSE | -6          | 85 LUTs       | >50       | 18   | N/A                       |
| MachXO2 <sup>™</sup> 1           | Verilog-Syn | -6          | 85 LUTs       | >50       | 18   | N/A                       |
| Mach AO2                         | VHDL-LSE    | -6          | 85 LUTs       | >50       | 18   | N/A                       |
|                                  | VHDL-Syn    | -6          | 86 LUTs       | >50       | 18   | N/A                       |
| MachXO <sup>™</sup> <sup>2</sup> | Verilog-LSE | -3          | 81 LUTs       | >50       | 18   | N/A                       |
|                                  | Verilog-Syn | -3          | 82 LUTs       | >50       | 18   | N/A                       |
|                                  | VHDL-LSE    | -3          | 81 LUTs       | >50       | 18   | N/A                       |
|                                  | VHDL-Syn    | -3          | 83 LUTs       | >50       | 18   | N/A                       |
| LatticeXP2 <sup>™ 4</sup>        | Verilog-Syn | <b>–</b> 5  | 93 LUTs       | >50       | 18   | N/A                       |
|                                  | VHDL-Syn    | <b>–</b> 5  | 93 LUTs       | >50       | 18   | N/A                       |
| ispMACH® 4000ZE <sup>5</sup>     | Verilog     | -5ns        | 64 Macrocells | >50       | 18   | N/A                       |
| ISPINIACH 4000ZE                 | VHDL        | -5ns        | 64 Macrocells | >50       | 18   | N/A                       |

<sup>1.</sup> Performance and utilization characteristics are generated using LCMXO2-1200HC-6TG144C with Lattice Diamond® 3.3 design software with LSE (Lattice Synthesis Engine) and Synplify Pro®.

## **Technical Support Assistance**

e-mail: techsupport@latticesemi.com

Internet: www.latticesemi.com

<sup>2.</sup> Performance and utilization characteristics are generated using LCMXO256E-3T100C with Lattice Diamond 3.3 design software with LSE and Synplify Pro.

<sup>3.</sup> Performance and tilization characteristics are genereted using LFE3-17EA-6FTN256C with Lattice Diamond 3.3 design software with Synplify Pro

<sup>4.</sup> Performance and utilization characteristics are generated using LFXP2-5E-5M132C with Lattice Diamond 3.3 design software with Synplify Pro.

<sup>5.</sup> Performance and utilization characteristics are generated using LC4256ZE-5TN100C with Lattice Diamond 3.3 design software with LSE.

<sup>6.</sup> Performance and utilization characteristics are generated using LFE5U-45F-6MG285C with Lattice Diamond 3.3 design software with LSE and Synplify Pro.

<sup>7.</sup> Performance and utilization characteristics are generated using LCMXO3L-4300C-6BG256C with Lattice Diamond 3.3 design software with LSE and Synplify Pro.



# **Revision History**

| Date           | Version | Change Summary                                                                                |  |
|----------------|---------|-----------------------------------------------------------------------------------------------|--|
| January 2015   | 2.7     | Updated Table 3, Performance and Resource Utilization.                                        |  |
|                |         | <ul> <li>Added support for Lattice Diamond 3.3 design software.</li> </ul>                    |  |
|                |         | <ul> <li>Added support for LSE and Synplify Pro.</li> </ul>                                   |  |
| March 2014     | 02.6    | Updated Table 3, Performance and Resource Utilization.                                        |  |
|                |         | <ul> <li>Added support for ECP5 device family.</li> </ul>                                     |  |
|                |         | <ul> <li>Added support for MachXO3L device family.</li> </ul>                                 |  |
|                |         | <ul> <li>Added support for Lattice Diamond 3.1 design software.</li> </ul>                    |  |
|                |         | Updated corporate logo.                                                                       |  |
|                |         | Updated Technical Support Assistance information.                                             |  |
| November 2010  | 02.4    | Added support for the MachXO2 device family.                                                  |  |
|                |         | Updated to support Lattice Diamond 1.1 design software.                                       |  |
|                |         | Updated to support ispLEVER 8.1 SP1 design software.                                          |  |
| December 2009  | 02.3    | Added support for LatticeXP2 device family.                                                   |  |
|                |         | Updated for ispLEVER 8.0.                                                                     |  |
| September 2009 | 02.2    | Design updated to include ispMACH 4000ZE support. Added VHDL source file and testbench.       |  |
| February 2009  | 02.1    | Design updated to include MachXO support. Document updates to reflect the design/tool change. |  |
| _              | _       | Previous Lattice releases.                                                                    |  |